package 第五周;

/**
 * @author xhw
 */

public class 找出字符串中第一个匹配项的下标 {

    public static void main(String[] args) {
        String haystack = "hello";
        String needle = "ll";
        int index = strStr(haystack, needle);

        System.out.println("匹配的第一个位置：" + index);
    }

    public static int strStr(String haystack, String needle) {
        if (needle.isEmpty()) return 0;

        int n = haystack.length();
        int m = needle.length();

        for (int i = 0; i <= n - m; i++) {
            int j;
            for (j = 0; j < m; j++) {
                if (haystack.charAt(i + j) != needle.charAt(j)) {
                    break;
                }
            }
            // 如果完全匹配，则返回当前的起始位置i
            if (j == m) {
                return i;
            }
        }

        // 如果没有找到匹配，返回-1
        return -1;
    }
}
